# PATENT ABSTRACTS OF JAPAN

(11)Publication number:

2001-142737

(43)Date of publication of application: 25.05.2001

(51)Int.CI.

G06F 11/28 G06F 9/46 G06F 12/02 G06F 12/10 G06F 12/14

(21)Application number: 11-319660

(71)Applicant: MATSUSHITA ELECTRIC IND CO LTD

(22)Date of filing:

10.11.1999

(72)Inventor: TANAKA HIROBUMI

# (54) MEMORY MANAGEMENT DEVICE

# (57)Abstract:

PROBLEM TO BE SOLVED: To provide a management device with high maintainability which realizes a reliable system to easily be constituted by allowing necessary tasks to share only necessary modules without modifying a program and disabling others to access a memory directly to prevent the contents of tasks stored in the memory from being broken and which can also monitor specific access to the memory.

SOLUTION: At a request to access a logical address which is not made to correspond to a physical address, a tracing means 108 performs mapping for making the logical address correspond to a physical address. A history of access to the local address which is not made to correspond is written to the physical address. A history acquiring means 110 obtains the history of access from the specific physical address of the memory in response to notification from the tracing means 108.



# **LEGAL STATUS**

[Date of request for examination]

[Date of sending the examiner's decision of rejection]

[Kind of final disposal of application other than the examiner's decision of rejection or application converted registration]

[Date of final disposal for application]

[Patent number]

[Date of registration]

[Number of appeal against examiner's decision of rejection]

[Date of requesting appeal against examiner's decision of rejection

[Date of extinction of right]

(19)日本国特許庁(JP)

ア・ル・

# 四公開特許公報(A)

(11)特許出願公開番号

特開2001-142737A) (P2001-142737A) (43)公開日 平成13年5月25日(2001.5.25)

| (51) Int. C I. 7 |       | 識別記号                   |    | FI      |            |     |     |     | テーマコード(参考)   |
|------------------|-------|------------------------|----|---------|------------|-----|-----|-----|--------------|
| G 0 6 F          | 11/28 |                        |    | G06F    | 11/28      |     |     | Α   | 5B005        |
|                  | 9/46  | 3 4 0                  |    |         | 9/46       | 3 4 | 4 0 | F   | 5B017        |
|                  | 12/02 | 5 7 0                  |    |         | 12/02      | 5   | 70  | D   | 5B042        |
|                  | 12/10 |                        |    |         | 12/10      |     |     | Н   | 5B060        |
|                  | 12/14 | 3 1 0                  |    |         | 12/14      | 3   | 10  | K   | 5B098        |
|                  | 審査請求  | 未請求 請求項の数7             | OL |         |            |     | (全1 | 6 ₺ | <u>[</u> ]   |
| (21) 出願番号        | 特縣    | 類平11-319660            |    | (71)出願人 | 000005     |     | 業株式 | 代会  | <b>社</b>     |
| (22)出願日          | 平月    | 成11年11月10日(1999.11.10) |    |         | 大阪府        | 門真市 | 市大  | 字門  | 真1006番地      |
|                  |       |                        |    | (72)発明者 |            |     |     |     |              |
|                  |       |                        |    |         | 大阪府<br>産業株 |     |     | 字門) | 真1006番地 松下電器 |
|                  | •     |                        |    | (74)代理人 | 100098     | 305 |     |     |              |
|                  |       | •                      | į  |         | 弁理士        | 福息  | 島神  | 人单  |              |
|                  |       |                        | İ  |         |            |     |     |     |              |
|                  |       |                        |    |         |            |     |     |     |              |
|                  |       |                        |    |         |            |     |     |     |              |
|                  | •     |                        |    |         |            |     |     |     |              |
|                  |       |                        |    |         |            |     |     |     | 最終頁に続く       |

# (54) 【発明の名称】メモリ管理装置

# (57)【要約】

【課題】 プログラムを変更することなく必要なモジュールのみ必要なタスク間で共有させ、それ以外はタスク間でメモリに直接アクセスできず、メモリに記憶されているタスクの内容が破壊されるのを防止して信頼性の高いシステムを容易に構成することができ、かつメモリの特定アクセスの監視が行える保守性の高い管理装置を提供する。

【解決手段】 トレース手段108は、物理アドレスに対応付けられていない未対応の論理アドレスへのアクセス要求があった場合、マッピング手段106に未対応の論理アドレスを物理アドレスに対応付けるマッピングを行わせる。そして未対応の論理アドレスへのアクセスの履歴がメモリの物理アドレスに書き込まれる。履歴取得手段110は、トレース手段108からの通知に応じてメモリの所定の物理アドレスからアクセスの履歴を取得する。



#### 【特許請求の範囲】

【請求項1】 メモリの物理アドレスを複数の論理アドレスへ対応付けるメモリ管理装置であって、

1

複数の論理アドレス空間と複数のモジュールとの対応関係を示す定義に基づいて、複数の論理アドレス空間のそれぞれにモジュールを配置する配置手段と、

複数のモジュールの物理アドレスを示すモジュール情報 に基づいて、前記配置手段によりモジュールが配置され た論理アドレス空間の論理アドレスへ物理アドレスを対 応付けるマッピング手段と、

タスクの切り換え指示に応答して、前記マッピング手段 により対応付けられた前記複数の論理アドレス空間の切 り換えを行う論理アドレス空間切り換え手段と、

前記論理アドレス空間切り換え手段により切り換えられた論理アドレス空間において物理アドレスに対応付けられていない未対応の論理アドレスへのアクセス要求があった場合に、前記マッピング手段に前記未対応の論理アドレスを前記メモリの第1の物理アドレスに対応付けを行わせて前記未対応の論理アドレスへのアクセスを実行させるとともに、前記未対応の論理アドレスへのアクセ 20 スの履歴を前記メモリの第2の物理アドレスに書き込ませるためのトレース手段と、

前記メモリの前記第2の物理アドレスからアクセスの履歴を取得する履歴取得手段とを備えたことを特徴とするメモリ管理装置。

【請求項2】 前記トレース手段は、前記未対応の論理 アドレスへのアクセスが終了した後、マッピング手段に よる前記未対応の論理アドレスと前記第1の物理アドレ スとの対応付けの解除を行わせることを特徴とする請求 項1記載のメモリ管理装置。

【請求項3】 前記トレース手段および前記履歴取得手段を間欠的に起動する管理手段をさらに備えたことを特徴とする請求項2記載のメモリ管理装置。

【請求項4】 前記管理手段は、前記トレース手段および前記履歴取得手段を所定時間ごとに起動することを特徴とする請求項3記載のメモリ管理装置。

【請求項5】 前記トレース手段は、前記管理手段により起動されていないときには、前記配置手段にモジュールの配置を行わせかつ前記マッピング手段に前記未対応の論理アドレスと前記第1の物理アドレスとの対応付け 40を行わせることを特徴とする請求項3または4記載のメモリ管理装置。

【請求項6】 前記トレース手段は、物理アドレスに対応付けられていない未対応の論理アドレスへのアクセス要求として書き込み要求があった場合に、前記第1の物理アドレスを前記第2の物理アドレスとして用い、前記第1の物理アドレスに前記未対応の論理アドレスのアクセスの履歴を書き込むことを特徴とする請求項1~5のいずれかに記載のメモリ管理装置。

【請求項7】 前記対応関係を示す定義は、前記複数の 50

論理アドレス空間にそれぞれ所属するセクションを定義 する空間定義と、各セクションに所属する一または複数 のモジュールを定義するセクション定義とを含み、

前記配置手段は、アクセスの履歴を取得する対象のセクションを定義するトレース定義に基づいて、前記トレース定義に定義されているセクションの論理アドレスと前記第1の物理アドレスとの対応付けを前記マッピング手段に解除させることが可能でかつ前記トレース定義に定義されたセクションの論理アドレスへ前記第1の物理アドレスとの対応付けを前記マッピング手段に実行させることが可能に構成されたことを特徴とする請求項1~6のいずれかに記載のメモリ管理装置。

#### 【発明の詳細な説明】

# [0001]

【発明の属する技術分野】本発明は、マルチタスクシステムで用いられるメモリ管理装置に関するものである。 【0002】

【従来の技術】近年、読み出し専用メモリ(ROM)にプログラムコードを配置した、いわゆる組み込み型マイクロコンピュータ制御システムにおいて、対象システムの複雑化に伴いプログラムサイズが増大しており、マルチタスクシステムを構成することが通例となっている。マルチタスクシステムにおいて、あるタスクが他のタスクで用いられる記憶情報を破壊するようなバグを持っている場合、バグの追求は非常に困難なため、解決に膨大な時間を要する。

【0003】最近の機器組み込み用マイクロプロセッサには、実行段階で機能する保護機構が搭載されつつある。そこで、上記のような問題を解決するため、そのような保護機構を利用して、バグが発生しうるプログラムを非特権モードで動作させ、バグが発生しえないプログラムを特権モードで動作させることによってマルチタスクシステムの誤動作を防止する方法が考えられる。

【0004】しかし、この方法では各プログラムを特権 モードおよび非特権モードのいずれで動作させるかを決 定することが困難である。また、同じモードで動作する プログラム同士は互いに破壊することができるため、完 全に問題を解決することはできない。

【0005】また、ワークステーションやパーソナルコンピュータ等のコンピュータの分野では、メモリ管理装置(MMU)を利用して各タスクを別の論理アドレス空間で動作させ、タスク間でメモリに直接アクセスできないようにすることによってこの問題を解決しているものがある。最近の機器組み込み用マイクロプロセッサの中にはメモリ管理装置を搭載しているものもあるため、このようなマイクロプロセッサでは、上記の問題を解決するためにコンピュータと同じようにタスク間でメモリに直接アクセスできないように構成することが考えられる。

) 【0006】しかし、組み込み型マイクロコンピュータ

制御システムでは、多くのタスクがコードやデータを共 有して密接に協調して動作するため、機器組み込み用マ イクロプロセッサにおいては、別々の論理アドレス空間 にタスクを分割することは非常に困難である。

【0007】ただし、同じ問題はコンピュータの分野に も存在し、従来のメモリ管理装置においては、タスク間 で直接アクセス可能な共有メモリを実現している。

【0008】図11は例えば特開平7-93210号公 報に記載されている共有メモリ管理方式を用いて共有メ モリを実現するための従来のメモリ管理装置の構成を示 10 すブロック図である。

【0009】図11に示すメモリ管理装置800は、メ モリ領域情報801および空間情報802を保持してい る。メモリ領域情報801には、メモリ領域を識別する ためのメモリ領域識別子とそのメモリ領域識別子が示す メモリ領域のメモリサイズ等のメモリ領域に関する情報 とがメモリ領域ごとに記述されている。空間情報802 には、論理アドレス空間を識別するための空間識別子と その空間識別子が示す論理アドレス空間に属するメモリ 領域とが論理アドレス空間ごとに記述されている。

【0010】このメモリ管理装置800は、アドレス変 換表803、マッピング手段804およびアドレス変換 表切り換え手段805を備える。マッピング手段804 は、アドレス変換表803を作成することによってメモ リ領域を論理アドレス空間にマッピングする。アドレス 変換表803は、各論理アドレス空間ごとに設けられ、 物理アドレスと論理アドレスとの間の変換を行う際に物 理アドレスと論理アドレスとの対応関係を指示する。ア ドレス変換表切り換え手段805は、タスクを切り換え 論理アドレス空間を切り換える。

【0011】図11に示す従来のメモリ管理装置800 においては、タスクが発行する共有メモリのマッピング 要求に応じてマッピング手段804が起動される。マッ ピング手段804は、マッピングすべき共有メモリにつ いてメモリ領域情報801を参照し、マッピングすべき 論理アドレス空間について空間情報802を参照し、そ してアドレス変換表803を作成することによって、共 有メモリのメモリ領域を論理アドレス空間にマッピング する。さらに、別のタスクで共有メモリのマッピング要 40 求が発行された場合にも、図9のメモリ管理装置800 は、同様の処理を行う。このように、複数のタスク間で 共有可能なメモリ領域を論理アドレス空間にマッピング することによって、アドレス変換表切り換え手段805 が論理アドレス空間を切り換えてもメモリ領域を共有す ることが可能となる。

# [0012]

【発明が解決しようとする課題】上記のように構成され た従来のメモリ管理装置800においては、タスクから の要求によって確保して共有しているメモリ領域では、

各タスクが動的に確保してアクセスするバッファメモリ やデータ構造に関してタスク間で共有できるのみである ため、プログラムで直接記述したコードやデータについ ては共有することができず、問題の解決にはならない。 【0013】さらに、メモリ管理装置800において は、アドレス変換表803を切り換えて論理アドレス空 間を切り換え、かつ共有メモリを複数のタスクが共有し ているため、メモリへの特定アクセスの監視が困難であ

【0014】本発明の目的は、プログラムを変更するこ となく必要なモジュールのみ必要なタスク間で共有さ せ、それ以外はタスク間でメモリに直接アクセスでき ず、メモリに記憶されているタスクの内容が破壊される のを防止して信頼性の高いシステムを容易に構築するこ とができ、かつメモリへの特定アクセスの監視が行える 保守性の高いメモリ管理装置を提供することである。

#### [0015]

【課題を解決するための手段】(1)第1の発明 第1の発明に係るメモリ管理装置は、メモリの物理アド レスを複数の論理アドレスへ対応付けるメモリ管理装置 であって、複数の論理アドレス空間と複数のモジュール との対応関係を示す定義に基づいて、複数の論理アドレ ス空間のそれぞれにモジュールを配置する配置手段と、 複数のモジュールの物理アドレスを示すモジュール情報 に基づいて、配置手段によりモジュールが配置された論 理アドレス空間の論理アドレスへ物理アドレスを対応付 けるマッピング手段と、タスクの切り換え指示に応答し て、マッピング手段により対応付けられた複数の論理ア ドレス空間の切り換えを行う論理アドレス空間切り換え る時にアドレス変換表803を切り換えることによって 30 手段と、論理アドレス空間切り換え手段により切り換え られた論理アドレス空間において物理アドレスに対応付 けられていない未対応の論理アドレスへのアクセス要求 があった場合に、マッピング手段に未対応の論理アドレ スをメモリの第1の物理アドレスに対応付けを行わせて 未対応の論理アドレスへのアクセスを実行させるととも に、未対応の論理アドレスへのアクセスの履歴をメモリ の第2の物理アドレスに書き込ませるためのトレース手 段と、メモリの第2の物理アドレスからアクセスの履歴 を取得する履歴取得手段とを備えるものである。

> 【0016】本発明に係るメモリ管理装置においては、 配置手段により定義に基づいて複数の論理アドレス空間 のそれぞれにモジュールが配置され、配置された論理ア ドレス空間の論理アドレスへ物理アドレスがモジュール 情報に基づいてマッピング手段により対応付けられる。 そのため、論理アドレス空間切り換え手段によりタスク の切り換え指示に応答して論理アドレス空間の切り換え が行われれば、切り換え前後の論理アドレス空間とモジ ュールとの対応関係がそれぞれ定義に示されているよう に定まる。したがって、異なるタスクにおいて必要とさ 50 れる同一のモジュールが定義により異なるタスクに共通

に対応することが示されていればその同一のモジュール は共有することができる。しかし、共有されるモジュー ル以外のモジュールは、異なるタスクの一方にのみ対応 することが定義に示されているので共有されない。それ により、必要なモジュール以外は異なるタスク間でメモ りに直接アクセスすることを禁止し、必要なモジュール のみ異なるタスク間で共有させることができる。

【0017】さらに、物理アドレスに対応付けられてい ない未対応の論理アドレスへのアクセス要求が契機とな って、トレース手段により未対応の論理アドレスでのア クセスの履歴が第2の物理アドレスに書き込まれ、履歴 取得手段により第2の物理アドレスへ書き込まれたアク セスの履歴が取得される。それにより、メモリへの特定 アクセスを監視することができる。

# 【0018】(2)第2の発明

第2の発明に係るメモリ管理装置は、第1の発明に係る メモリ管理装置の構成において、トレース手段は、未対 応の論理アドレスへのアクセスが終了した後、未対応の 論理アドレスと第1の物理アドレスとの対応付けを解除 させるものである。

【0019】この場合、トレース手段が繰り返し論理ア ドレスに対応付けられていない未対応の論理アドレスへ のアクセス要求を検出して、履歴取得手段が繰り返しア クセスの履歴を取得することができる。

# 【0020】(3)第3の発明

第3の発明に係るメモリ管理装置は、第2の発明に係る メモリ管理装置の構成において、トレース手段を間欠的 に起動する管理手段をさらに備えたものである。

【0021】この場合、トレース手段が間欠的に起動さ リ管理装置の動作を効率化することができる。

# 【0022】(4)第4の発明

第4の発明に係るメモリ管理装置は、第3の発明に係る メモリ管理装置の構成において、管理手段は、トレース 手段および履歴取得手段を所定時間ごとに起動するもの・ である。

【0023】この場合、所定時間ごとにメモリへの特定 アクセスを監視することができる。

# 【0024】(5)第5の発明

第5の発明に係るメモリ管理装置は、第3または第4の 発明に係るメモリ管理装置の構成において、トレース手 段は、管理手段により起動されていないときには、配置 手段にモジュールの配置を行わせかつマッピング手段に 未対応の論理アドレスと第1の物理アドレスへの対応付 けを行わせるものである。

【0025】この場合、トレース手段が起動されていな いときにも第1の物理アドレスへのアクセスが可能にな

# 【0026】(6)第6の発明

れかの発明に係るメモリ管理装置の構成において、トレ ース手段は、物理アドレスに対応付けられていない未対 応の論理アドレスへのアクセス要求として書き込み要求 があった場合に、第1の物理アドレスを第2の物理アド レスとして用い、第1の物理アドレスに未対応の論理ア ドレスのアクセスの履歴を書き込むものである。

【0027】この場合、アクセスの履歴をメモリの第2 の物理アドレスに書き込ませるためのトレース手段の機 能を簡略化でき、メモリ管理装置を簡素化できる。

#### 【0028】(7)第7の発明 10

第7の発明に係るメモリ管理装置は、第1~第6のいず れかの発明に係るメモリ管理装置の構成において、定義 は、複数の論理アドレス空間にそれぞれ所属するセクシ ョンを定義する空間定義と、各セクションに所属する一 または複数のモジュールを定義するセクション定義とを 含み、配置手段は、アクセスの履歴を取得する対象のセ クションを定義するトレース定義に基づいて、トレース 定義に定義されているセクションの論理アドレスと第1 の物理アドレスとの対応付けをマッピング手段に解除さ 20 せることが可能でかつトレース定義に定義されたセクシ ョンの論理アドレスへ第1の物理アドレスとの対応付け をマッピング手段に実行させることが可能に構成された ものである。

【0029】この場合、トレース定義にセクションを定 義するという簡単な操作でアクセスの履歴を取得できる ようになる。

#### [0030]

【発明の実施の形態】(実施の形態1)以下、本発明の 実施の形態1におけるメモリ管理装置について説明す れるため、アクセスの履歴の取得回数を制限して、メモ 30 る。図1は、実施の形態1におけるメモリ管理装置の構 成を示すブロック図である。

> 【0031】図1のメモリ管理装置100は、複数のモ ジュール情報 101、複数のセクション定義 102 およ び複数の空間定義103を保持している。

> 【0032】モジュール情報101は、モジュールを識 別するためのモジュール識別子と、そのモジュール識別 子が示すモジュールのコードやデータのサイズ等のプロ グラムに関する情報とをモジュールごとに記述してい

【0033】また、セクション定義102は、セクショ 40 ンを識別するためのセクション識別子と、そのセクショ ン識別子が示すセクションに所属する1つまたは複数の モジュールを識別するためのモジュール識別子とをセク ションごとに定義する。

【0034】さらに、空間定義103は、論理アドレス 空間を識別するための空間識別子と、その空間識別子が 示す論理アドレス空間に所属するしつまたは複数のセク ションを識別するためのセクション識別子と、その空間 識別子が示す論理アドレス空間に切り換えるタスクを識 第6の発明に係るメモリ管理装置は、第1~第5のいず 50 別するタスク識別子とを論理アドレス空間ごとに定義す

る。

【0035】メモリ管理装置100は、配置手段104、複数のアドレス変換表105、マッピング手段106、アドレス変換表切り換え手段107、トレース手段108および履歴取得手段110を備える。

【0036】配置手段104は、モジュール情報101とセクション定義102と空間定義103とに基づき、複数の論理アドレス空間のそれぞれに所属するセクションを読み取り、複数の論理アドレス空間のそれぞれのセクションについてモジュールの配置を決定する。すなわち、配置手段104は、複数の論理アドレス空間のそれぞれにおいてモジュールの配置を決定する。

【0037】マッピング手段106は、アドレス変換表105を作成することによって、論理アドレス空間ごとに配置されているモジュールについて論理アドレスと物理アドレスとの対応関係を決定するためのマッピングを行う。

【0038】複数のアドレス変換表105のそれぞれは、複数の論理アドレス空間の中の1つと一対一に対応しており、そのためそれぞれ複数のタスクの中の1つと一対一に対応しており、対応する論理アドレス空間(タスク)における論理アドレスと物理アドレスとの対応関係を示している。

【0039】アドレス変換表切り換え手段107は、タスクの切り換え指示に応じて、アドレス変換表105を切り換える。アドレス変換表105が論理アドレス空間と一対一に対応していることからアドレス変換表105の切り換えは論理アドレス空間の切り換えを意味する。

【0040】トレース手段108は、プログラムの実行 中に、アドレス変換表切り換え手段107により切り換 30 えられたアドレス変換表105において物理アドレスに 対応付けられていない未対応の論理アドレスへの書き込 み要求の有無を検出する。この物理アドレスに対応付け られていない未対応の論理アドレスへの書き込み要求 は、物理アドレスに対応付けられていない未対応の論理 アドレスへのアクセス要求の一種であり、このような書 き込み要求およびアクセス要求をアクセス例外と呼ぶ。 トレース手段108は、未対応の論理アドレスへの書き 込み要求を検出すると、未対応の論理アドレスを所定の 物理アドレスへのマッピングをマッピング手段106に 行わせる。トレース手段108は、物理アドレスへの書 き込みが終了した後、マッピング手段106に所定の物 理アドレスと論理アドレスとのマッピングを解除させ る。

【0041】履歴取得手段110は、アクセス例外の発生の通知に応じて、所定の物理アドレスに新たに書き込まれたアクセスの履歴を取得する。

【0042】本実施の形態では、アドレス変換表105 よび表2に示すアドレス変換表を作成することによっ およびアドレス変換表切り換え手段107は論理アドレ て、図3に示すマッピングを行う。ただし、アクセス例 ス空間切り換え手段に相当し、セクション定義102お 50 外が発生していないときには、表2の点線で囲まれた論

よび空間定義103が対応関係を示す定義に相当する。 【0043】なお、配置手段104、マッピング手段1 06、アドレス変換表切り換え手段107、トレース手 段108および履歴取得手段110は、CPU(中央演 算処理装置)がROM(リードオンリメモリ)等の記憶 装置に記憶されたプログラムをRAM(ランダムアクセ スメモリ)等のメモリ上で実行することにより実現され る。また、モジュール情報101、セクション定義10 2および空間定義103は、ファイルとしてROM、ハ ードディスク装置等の記憶装置に予め記憶される。さら に、アドレス変換表105は、マッピング手段106に より作成された後、RAM、ハードディスク装置等の記 憶装置に格納される。

【0044】図2は、メモリ管理装置100が保持しているモジュール情報101、セクション定義102および空間定義103の一例を示す概念図である。図3は、メモリ管理装置100が行ったマッピングの一例を示す概念図である。

【0045】メモリ管理装置100は、図2のモジュー20 ル情報101には、「モジュール1」、「モジュール2」および「モジュール3」というモジュールをそれぞれ示すモジュール識別子211~213が示すモジュールのコードアドレス、コードサイズ、データアドレスおよびデータサイズとが記述されている。

【0046】セクション定義102には、「セクション1」、「セクション2」および「セクション3」というセクションをそれぞれ示すセクション識別子221~223が示すセクションにそれぞれ属する「モジュール1」、「モジュール2」および「モジュール3」というモジュールをそれぞれ示すモジュール識別子211~213とが定義されている。

【0047】空間定義103には、「空間1」および「空間2」という論理アドレス空間をそれぞれ示す空間識別子231,232と、各空間識別子231,232が示す論理アドレス空間に属する「セクション1」、「セクション2」および「セクション3」というセクションをそれぞれ示すセクション識別子221~223と、各空間識別子231,232が示す論理アドレス空間が属する「タスク1」および「タスク2」というタスクをそれぞれ示すタスク識別子241,242とが定義されている。

【0048】図2に示すモジュール情報101とセクション定義102と空間定義103とを用いて、空間識別子231.232で示される「空間1」および「空間2」という論理アドレス空間について、それぞれ表1および表2に示すアドレス変換表を作成することによって、図3に示すマッピングを行う。ただし、アクセス例外が発生していないときには、表2の点線で囲まれた論

理アドレス「0×3100000」と物理アドレス 「0 x 9 0 0 0 8 0 0 0」とのマッピングは行われてい ない。

[0049] 【表1】

| 論理アドレス     | 物理アドレス     |
|------------|------------|
| 0x10000000 | 0x80000000 |
| 0x11000000 | 0x80001000 |
| 0x20000000 | 0x90000000 |
| 0x21000000 | 0x90001000 |

[0050] 【表2】

| 論理アドレス     | 物理アドレス     |
|------------|------------|
| 0x11000000 | 0x80001000 |
| 0x12000000 | 0×80002000 |
| 0x21000000 | 0x90001000 |
| 0x22000000 | 0x90002000 |
| 0x31000000 | 0x90008000 |

【0051】なお、図3においては、2つの論理アドレ ス空間LA、LBと物理アドレス空間PSとの対応関係 が示されている。本例では、論理アドレス空間LAが 「空間1」に相当し、論理アドレス空間LBが「空間 2」に相当する。

【0052】次に、メモリ管理装置100の動作につい て説明する。メモリ管理装置100はシステム初期化時 に、図3に示すマッピングを行うために配置手段104 を起動する。起動された配置手段104は、さらにマッ ピング手段106を起動する。

【0053】配置手段104は、空間定義103を参照 し、空間識別子231により示される「空間1」という 論理アドレス空間にセクション識別子221により示さ れる「セクション1」が所属することを読み取る。

【0054】次に配置手段104は、セクション定義1 02を参照し、セクション識別子221により示される 「セクション」」にモジュール識別子211により示さ れる「モジュール1」が所属することを読み取る。

【0055】さらに、配置手段104は、モジュール情 報!01を参照し、モジュール識別子211により示さ れる「モジュール」」のコードアドレス、コードサイ ズ、データアドレスおよびデータサイズを読み取る。そ して、配置手段104は、モジュール識別子211によ り示される「モジュール丨」のコードアドレスおよびデ 50 00」および「0x2l000000」に「モジュール

ータアドレスを、空間識別子231により示される「空 間1」という論理アドレス空間上に配置する。それによ り、「モジュール1」が「空間1」に配置される。

10

【0056】次に、配置手段104は、空間識別子23 1により示される「空間1」という論理アドレス空間に セクション識別子222により示される「セクション 2」が所属することを読み取り、「セクション1」の場 合と同様に、空間定義103とセクション定義102と モジュール情報101に基づき、モジュール識別子21 10 2により示される「モジュール2」のコードアドレスと データアドレスとを空間識別子231により示される 「空間1」という論理アドレス空間上に配置する。それ により、「モジュール2」が「空間1」に配置される。 【0057】同様に、配置手段104は、空間定義10 3を参照し、空間識別子232により示される「空間 2」という論理アドレス空間にセクション識別子222 により示される「セクション2」が所属することを読み 取り、空間定義103とセクション定義102とモジュ ール情報101に基づき、モジュール識別子212に示 20 される「モジュール 2」のコードアドレスとデータアド レスとを空間識別子232により示される「空間2」と いう論理アドレス空間上に配置する。それにより、「モ ジュール2」が「空間2」に配置される。

【0058】また、配置手段104は、空間定義103 を参照し、空間識別子232により示される「空間2」 という論理アドレス空間にセクション識別子223によ り示される「セクション3」が所属することを読み取 り、空間定義103とセクション定義102とモジュー ル情報101に基づき、モジュール識別子213により 30 示される「モジュール 3」のコードアドレスとデータア ドレスとを空間識別子232により示される「空間2」 という論理アドレス空間上に配置する。それにより、 「モジュール3」が「空間2」に配置される。

【0059】マッピング手段106は、空間識別子23 1により示される「空間1」という論理アドレス空間に おいて、配置手段104によってコードアドレスおよび データアドレスが配置された論理アドレスに物理アドレ スを対応させ、表1に示すアドレス変換表105を作成 する。

40 【0060】次に、マッピング手段106は、空間識別 子232により示される「空間2」という論理アドレス 空間において、配置手段104によってコードアドレス およびデータアドレスが配置された論理アドレスに物理 アドレスを対応させ、表2に示すアドレス変換表105 を作成する。

【0061】上記の場合、「空間1」および「空間2」 の両方にモジュール識別子212により示される「モジ ュール2」が所属しているので、配置手段104は、論 理アドレス空間LAの論理アドレス「0 x 1 1 0 0 0 0

2」のコードアドレスおよびデータアドレスをそれぞれ 配置する。それにより、マッピング手段106は、物理 アドレス「0x80001000」を論理アドレス空間 LAの論理アドレス「0x1100000」および論 理アドレス空間LBの論理アドレス「0xll0000 00 | ヘマッピングする。

【0062】同様に、マッピング手段106は、物理ア ドレス「0 x 9 0 0 0 1 0 0 0」を論理アドレス空間し Aの論理アドレス「0x2100000」および論理 アドレス空間LBの論理アドレス「0x210000 0」ヘマッピングする。

【0063】このように、図3の論理アドレス空間し A, LBと物理アドレス空間PSとの対応関係が決定さ れる。

【0064】マッピング手段106は、これらアドレス 変換表105を作成する際に、空間定義103を参照し てタスクと論理アドレス空間との関連づけを行ってい る。アドレス変換表切り換え手段107は、表1が「タ スク1」に対応し、表2が「タスク2」に対応するとい う情報を保持している。

【0065】システム初期化終了後、アドレス変換表切 り換え手段107は、タスクの切り換え指示に応じて、 表 1 および表 2 に示したようなアドレス変換表 1 0 5 の 切り換えを行う。

【0066】例えば、タスク識別子241により示され る「タスク1」を行った後に、タスク識別子242によ り示される「タスク2」を行う場合、アドレス変換表切 り換え手段107は、アドレス変換表105を、空間識 別子231により示される「空間1」という論理アドレ ス空間に対応した表1から空間識別子232により示さ れる「空間2」という論理アドレス空間に対応した表2 へと切り換える。つまり、アドレス変換表切り換え手段 107は、アドレス変換表105を切り換えることによ って、「空間1」から「空間2」への切り換えを行って

【0067】本実施の形態のメモリ管理装置100によ れば、配置手段104およびマッピング手段106によ って、「空間1」および「空間2」という異なる論理ア ドレス空間に所属する同一の「モジュール 2」が同一の 物理アドレスに割り付けられるように、論理アドレス空 40 間ごとにマッピングが行われる。それにより、タスクの 切り換えに応じてアドレス変換表切り換え手段107が 「空間1」および「空間2」の切り換えを行っても「モ ジュール2」を共通に使用することができる。つまり、 メモリ管理装置100では、タスク識別子241により 示される「タスク1」およびタスク識別子242により 示される「タスク2」のような互いに異なる2つのタス クが同一の「モジュール2」を共有することができる。

【0068】次にメモリへのアクセスの履歴の取得につ

ムの実行中に、物理アドレス空間PSにマッピングされ ていない論理アドレスへの鸖き込み要求(アクセス例 外)を検出する。例えば、アドレス変換表切り換え手段 107により表2のアドレス変換表105が選択されて いて、論理アドレス「0x3100000」に鸖き込 み要求があった場合に、トレース手段108は論理アド レス「0 x 3 1 0 0 0 0 0 0」というマッピングされて いない論理アドレスに書き込み要求があったこと(アク セス例外)を検出する。

12

10 【0069】トレース手段108は、アクセス例外を検 出すると、マッピングされていない論理アドレスを物理 アドレス空間PSの所定の物理アドレスにマッピング手 段106によりマッピングさせる。例えば、マッピング 手段106が、物理アドレス空間PSの物理アドレス 「0 x 9 0 0 0 8 0 0 0」に論理アドレス「0 x 3 1 0 00000」をマッピングする。そして、トレース手段 108は、論理アドレスへの書き込み要求を実行させ る。例えば、論理アドレス「0x3100000」へ の書き込み命令を実行させる。それにより、物理アドレ 20 ス「0 x 9 0 0 0 8 0 0 0」に何らかのデータの書き込 みが行われる。

【0070】その後、トレース手段108は、書き込み 要求に応じてマッピングした物理アドレスと論理アドレ スとのマッピングをマッピング手段106に解除させ る。例えば、物理アドレス「0x90008000」と 物理アドレス「0x31000000」とのマッピング をマッピング手段106に解除させる。それにより、再 び論理アドレス「0 x 3 1 0 0 0 0 0 0 」に書き込み要 求があった場合にトレース手段108によりアクセス例 外を検出することができる。

【0071】アクセスの履歴の取得は、履歴取得手段1 10が予め定められている物理アドレスの内容を読み出 すことにより行われる。アクセスの履歴が書き込まれる 物理アドレスは予め定められているので、履歴取得手段 110は、マッピングが解除されてもアクセスの履歴を 取得できる。例えば、所定の物理アドレス「0 x 9 0 0 08000」に書き込まれるデータが論理アドレス「0 x3100000」への書き込み要求の有無を示すフ ラグである場合には、物理アドレス「0x900080 00」のデータを読み出すことにより論理アドレス「0 x3100000」へのアクセスの有無を監視するこ

【0072】また、所定の物理アドレス「0x9000 8000」に書き込まれるデータが論理アドレス「0x 3 1 0 0 0 0 0 0 」への書き込み要求の回数を示すカウ ント値である場合には、物理アドレス「0 x 9 0 0 0 8 000」のデータを読み出すことにより論理アドレス 「0 x 3 1 0 0 0 0 0 0」へのアクセス回数を監視する ことができる。このような鸖き込みを行わせるために、 いて説明する。図1のトレース手段108は、プログラ 50 プログラム中に、論理アドレス「0x310000

13

0」へフラグの書き込みを行う命令やカウント値の書き 込みを行う命令を記述しておく。

【0073】本実施の形態のメモリ管理装置100によ れば、未対応の論理アドレス「0 x 3 1 0 0 0 0 0 0 」 へのアクセス要求が契機となって、トレース手段108 により論理アドレス「0x3100000」へのアク セスの履歴が物理アドレス「0 x 9 0 0 0 8 0 0 0」へ **掛き込まれたときに、履歴取得手段110が論理アドレ** ス「0x3100000」へのアクセスの履歴を物理 アドレス「0 x 9 0 0 0 8 0 0 0 」から取得して、メモ 10 別するためのセクション識別子とを定義する。 リへの特定アクセスを監視することができる。それによ り、メモリ管理装置100の保守性を高めることができ る。

【0074】なお、図2では、「モジュール1」~「モ ジュール3」と「セクション1」~「セクション3」と が一対一で対応する場合について説明したが、図4に示 すようにセクション識別子224により示される1つの 「セクション4」にモジュール識別子211,212に より示される複数の「モジュール 1」および「モジュー ル2」が対応し、セクション識別子225により示され 20 る1つの「セクション5」にモジュール識別子212. 2 1 3 により示される複数の「モジュール 2 」および 「モジュール3」が対応し、セクション識別子226に より示される「セクション6」にモジュール識別子21 4により示される「モジュール4」が対応するように構 成することができる。

【0075】例えば「セクション4」を特権モードで取 り扱われるモジュールの集合と定義し、別の「セクショ ン5」を非特権モードで取り扱われるモジュールの集合 と定義することにより、「セクション4」および「セク ション5」で「モジュール2」の取り扱い規定を別々に 設けることができる。それにより、同じ機能を持ちなが ら異なる取り扱い規定としなければならないモジュール を、空間識別子233,234によりぞれぞれ示される 「空間3」および「空間4」という論理アドレス空間に おいて、タスク識別子243,244により示される 「タスク3」および「タスク4」の間で共有することが できる。

【0076】(実施の形態2)図5は本発明の実施の形 態2におけるメモリ管理装置の構成を示すブロック図で 40 ある。

【0077】図5に示すメモリ管理装置300は、配置 手段304、複数のアドレス変換表105、マッピング 手段306、アドレス変換表切り換え手段107および トレース手段308を備える。

【0078】図5のメモリ管理装置300は、図1のメ モリ管理装置100と同様に、複数のモジュール情報1 01、複数のセクション定義102および複数の空間定 義103を保持している。メモリ管理装置300は、図 1のメモリ管理装置 100と異なり、トレース定義 30 50 06、トレース手段 308 および履歴取得手段 310

9を保持している。

【0079】メモリ管理装置300は、トレース定義3 09を保持しており、配置手段304、マッピング手段 306およびトレース手段308の機能がメモリ管理装 置100の配置手段104、マッピング手段106およ びトレース手段108と相違する。

【0080】トレース定義309は、トレースを識別す るためのトレース識別子と、そのトレース識別子が示す セクションに所属するしつまたは複数のセクションを識

【0081】配置手段304は、モジュール情報101 とセクション定義102と空間定義103とに基づき、 複数の論理アドレス空間のそれぞれに所属するセクショ ンを読み取り、複数の論理アドレス空間のそれぞれのセ クションについてモジュールの配置を決定する。また、 配置手段304は、後述するトレース手段308からの アクセス例外の検出の通知を受けて、セクション定義1 02とモジュール情報101と空間定義103とに基づ き、アドレス変換表105に対応する論理空間にアクセ ス要求の出ているセクションのモジュールを配置し、後 述するマッピング手段306にマッピングさせる。さら に、配置手段304は、トレース定義309に基づい て、マッピングを解除すべきセクションを後述するマッ ピング手段306に指示する。

【0082】マッピング手段306は、アドレス変換表 105を作成することによって、配置手段304により 論理アドレス空間ごとに配置されているモジュールにつ いて論理アドレスと物理アドレスとの対応関係を決定す るためのマッピングを行う。また、マッピング手段30 6は、配置手段304からの指定されたセクションの論 理アドレスと物理アドレスとの対応関係を解除する。

【0083】トレース手段308は、プログラムの実行 中に、物理アドレスに対応付けられていない未対応の論 理アドレスへのアクセス要求(アクセス例外)を検出す る。未対応の論理アドレスへのアクセス要求には、メモ リへの書き込み要求以外にメモリからの読み出し要求が 含まれる。トレース手段308は、アクセス例外を検出 すると、アクセス例外を検出したことを配置手段304 に通知する。また、トレース手段308は、未対応の論 理アドレスへのアクセスを行うステップ実行の終了を検 出して、配置手段304にマッピングの解除を指示す

【0084】履歴取得手段110は、トレース手段30 8から与えられるアクセス例外の発生の通知に応じて、 マッピング手段306がマッピングを解除する前に、マ ッピング手段306のマッピングにより未対応の論理ア ドレスへ対応付けられた物理アドレスからアクセス履歴 を取得する。

【0085】なお、配置手段304、マッピング手段3

は、CPUがROM等の記憶装置に記憶されたプログラムをRAM等のメモリ上で実行することにより実現される。また、トレース定義309は、ファイルとしてROM、ハードディスク装置等の記憶装置に予め記憶される。

【0086】図6は、メモリ管理装置300が保持しているモジュール情報101、セクション定義102、空間定義103およびトレース定義309の構成を示す概念図である。図7はメモリ管理装置300が行ったマッピングの一例を示す概念図である。

【0087】図6のモジュール情報101、セクション定義102および空間定義103の構成は図2のモジュール情報101、セクション定義102および空間定義103と同様である。トレース定義309には、「トレース1」というトレースを示すトレース識別子250と、「トレース1」に属する「セクション3」というセクションを示すセクション識別子251が定義されている。

【0088】図6に示すモジュール情報101、セクション定義102および空間定義103を用いて空間識別20子231、232で示される「空間1」および「空間2」という論理アドレス空間について、それぞれ表3および表4に示すアドレス変換表を作成することによって図7に示すマッピングを行う。ただし、表4の点線で囲まれた論理アドレス「0x120000」と物理アドレス「0x8000200」とのマッピング、および論理アドレス「0x220000」と物理アドレス「0x9000200」とのマッピングはアクセス例外が発生していない状態では解除されている。

[0089]

【表 3】

| 論理アドレス     | 物理アドレス     |  |  |  |  |
|------------|------------|--|--|--|--|
| 0x10000000 | 0x80000000 |  |  |  |  |
| 0x11000000 | 0x80001000 |  |  |  |  |
| 0x20000000 | 0x90000000 |  |  |  |  |
| 0x21000000 | 0x90001000 |  |  |  |  |

【0090】 【表4】

| 論理アドレス     | 物理アドレス     |
|------------|------------|
| 0x11000000 | 0x80001000 |
| 0x21000000 | 0x90001000 |
| 0x12000000 | 0x80002000 |
| 0x22000000 | 0x90002000 |

0 【0091】なお、図7における2つの論理アドレス空間LA、LBと「空間1」、「空間2」との対応関係は図3の場合と同様である。

【0092】次に、メモリ管理装置300の動作について説明する。メモリ管理装置300はシステム初期化時に、図7に示すマッピングを行うために配置手段304 を起動する。起動された配置手段304は、さらにマッピング手段306を起動する。配置手段304 およびマッピング手段306は、まず図1のメモリ管理装置100と同様にして、図3に示すマッピングを行う。

【0093】次に、配置手段304は、トレース定義309を参照し、トレース識別子250により示される「トレース1」というトレースにセクション識別子251により示される「セクション3」が所属することを読み取る。

【0094】配置手段304は、空間定義103を参照し、「空間2」に「セクション3」が所属することを読み取る。次に、配置手段304は、セクション定義102を参照し、「セクション3」に「モジュール3」が所属することを読み取る。さらに、配置手段304は、モジュール情報101を参照し、「モジュール3」のコードアドレスをデータアドレスならびにコードサイズおよびデータサイズを読み取る。それにより、解除すべき物理アドレスが配置手段304に認識される。そして、配置手段304は、「セクション3」についての論理アドレスと物理アドレスとの解除をマッピング手段306に指示する。

【0095】次に、マッピング手段306は配置手段304からの指示に応じ、表2に示す論理アドレス「0x1200000」と物理アドレス「0x80002000」との対応付けおよび論理アドレス「0x22000000」と物理アドレス「0x90002000」と対応付けを解除して、論理アドレス「0x1100000」と物理アドレス「0x80001000」とのマッピングおよび論理アドレス「0x21000000」と物理アドレス「0x90001000」とのマッピングを残して表4に示すアドレス変換表を作成する。

【0096】システム初期化終了後、メモリ管理装置300のアドレス変換表切り換え手段107がタスクの切り換え指示に応じて、表3および表4に示したようなアドトスで作事より50円的特点を行ってもようなアドト

50 ドレス変換表105の切り換えを行ってタスクの切り換

えを行うのは、図1のメモリ管理装置100と同様であ

【0097】本実施の形態のメモリ管理装置300によ れば、図1のメモリ管理装置100と同様に、タスク識 別子241により示される「タスク1」およびタスク識 別子242により示される「タスク2」のような互いに 異なる2つのタスクが同一の「モジュール2」を共有す ることができる。

【0098】次にメモリへのアクセス履歴の取得につい て説明する。図5のトレース手段308は、プログラム 実行中に、マッピングされていない論理アドレスに書き 込み要求があったこと(アクセス例外)を検出する。例 えば、アドレス変換表切り換え手段107により表4の アドレス変換表 105が選択されていて、「セクション 3」の論理アドレスへの書き込み要求があった場合にト レース手段308はアクセス例外を検出する。

【0099】トレース手段308は、アクセス例外を検 出すると、マッピングされていない「セクション3」に ついてのマッピングを配置手段304に指示する。配置 手段304は、「空間2」において、セクション定義1 02およびモジュール情報101に基づき、「セクショ ン3」の配置を行う。その後、配置手段304は、マッ ピング手段306を起動して、配置手段304が行った 「セクション3」の配置に基づいて、「セクション3」 のマッピングを行わせる。例えば、マッピング手段30 6は、図7に示すように論理アドレス「0x12000 000」を物理アドレス「0x8000200」にマ ッピングするとともに「0 x 2 2 0 0 0 0 0 0」を物理 アドレス「0 x 9 0 0 0 2 0 0 0」にマッピングする。 そして、「モジュール3」のステップ実行により、「モ ジュール3」の実行を示すフラグが物理アドレス「0 x 90002000」に魯き込まれる。

【0100】トレース手段308は、アクセス例外が発 生したことを履歴取得手段310に通知する。履歴取得 手段310は、マッピング手段306が行ったマッピン グに基づいて、物理アドレス「0 x 9 0 0 0 2 0 0 0」 から「モジュール3」の実行を示すフラグを取得する。

【0 1 0 1】その後、トレース手段 3 0 8 は、「セクシ ョン3」のマッピングの解除を配置手段304に指示す る。配置手段304は、マッピング手段306に「セク ション3」のマッピングを解除させる。それにより、新 たに「セクション3」の論理アドレスにアクセス要求が あった場合に、トレース手段308は、アクセス例外を 検出することができる。

【0102】本実施の形態のメモリ管理装置300によ れば、「セクション3」の未対応の論理アドレスへのア クセス要求が契機となって、トレース手段308により 「セクション3」の論理アドレスへのアクセスの履歴が 物理アドレス「0 x 9 0 0 0 2 0 0 0」へ書き込まれた ときには、履歴取得手段310が「セクション3」の論 50 成することによって、図9に示すマッピングが行われる

理アドレスへのアクセスの履歴を物理アドレスから取得 して、メモリへの特定アクセスを監視することができ る。それにより、メモリ管理装置300の保守性を髙め ることができる。

【0103】 (実施の形態3)図8は本発明の実施の形 態3におけるメモリ管理装置の構成を示すブロック図で

【0104】図8に示すメモリ管理装置400は、配置 手段304、複数のアドレス変換表105、マッピング 10 手段306、アドレス変換表107、トレース手段40 8および履歴取得手段410を備える。

【0105】図8のメモリ管理装置400は、図5のメ モリ管理装置300と同様に、複数のモジュール情報1 01、複数のセクション定義102、複数の空間定義1 03およびトレース定義309を保持している。

【0106】メモリ管理装置400は、トレース手段4

08および履歴取得手段410の機能が図5に示すメモ リ管理装置300と異なっている。メモリ管理装置40 0において、トレース手段408および履歴取得手段4 10以外の構成はメモリ管理装置300と同様である。 【0107】トレース手段408は、プログラムの実行 中に物理アドレスに対応付けられていない未対応の論理 アドレスへのアクセス要求 (アクセス例外) を検出す る。トレース手段408は、アクセス例外を検出する と、配置手段304にトレース定義309を参照させ、 アクセス要求の出ているセクションについて、モジュー ル情報 101とセクション定義 102と空間定義 103 とに基づき、配置手段104に現在用いられているアド レス変換表105に対応する論理空間にアクセス要求の 出ているセクションのモジュールを配置させる。

【0 1 0 8】また、トレース手段 4 0 8 は、未対応の論 理アドレスへのアクセスを行うステップ実行の終了を検 出して配置手段304にマッピング解除を指示するとと もに、所定の物理アドレスへアクセスの履歴を書き込

【0109】履歴取得手段410はトレース手段408 から与えられるアクセス例外の発生の通知に応答して、 トレース手段308がアクセスの履歴を書き込んだ所定 の物理アドレスからアクセスの履歴を取得する。

【0 1 1 0】 なお、トレース手段 4 0 8 および履歴取得 手段410は、CPUがROM等の記憶装置に記憶され たプログラムをRAM等のメモリ上で実行することによ り実現される。

【0111】メモリ管理装置400は、図6に示す構成 を有するモジュール情報 101、セクション定義 10 2、空間定義 1 0 3 およびトレース定義 3 0 9 を保持し ている。図9は、メモリ管理装置400が行ったマッピ ングの一例を示す概念図である。

【0 1 1 2】表 3 および表 4 に示すアドレス変換表を作

のは、メモリ管理装置300の場合と同様である。

【0 1 1 3】次に、メモリ管理装置 4 0 0 の動作につい て説明する。メモリ管理装置400はシステム初期化時 に、図9に示すマッピングを行うために配置手段304 を起動する。起動された配置手段304は、さらにマッ ピング手段306を起動する。配置手段304およびマ ッピング手段306は、図5のメモリ管理装置300と 同様にして、図9に示すマッピングを行う。

【0 1 1 4 】次に、配置手段 3 0 4 は、モジュール情報 101、セクション定義102、空間定義103および トレース定義309を参照し、図5のメモリ管理装置3 00と同様にして、「セクション3」のマッピングの解 除を行う。

【0115】システム初期化終了後、メモリ管理装置4 00のアドレス変換表切り換え手段107がタスクの切 り換え指示に応じて、表3および表4に示したようなア ドレス変換表の切り換えを行ってタスクの切り換えを行 うのは、図5のメモリ管理装置300と同様である。

【0 1 1 6】本実施の形態のメモリ管理装置400によ れば、図5のメモリ管理装置300と同様に、タスク識 20 別子241により「タスク1」およびタスク識別子24 2により示される「タスク2」のような互いに異なる2 つのタスクが同一の「モジュール2」を共有することが

【0117】次にメモリへのアクセス履歴の取得につい て説明する。図8のトレース手段408は、アクセス例 外の検出を行う。例えば、アドレス変換表切り換え手段 107により表4のアドレス変換表105が選択されて いて、「セクション3」の論理アドレスにアクセスの要 求があった場合に、トレース手段408は、マッピング 30 されていない論理アドレスにアクセスの要求があったこ と(アクセス例外)を検出する。

【0118】トレース手段408は、アクセス例外を検 出すると、マッピングされていない「セクション3」に ついてのマッピングを配置手段304に指示する。配置 手段304は、「空間2」において、セクション定義1 02およびモジュール情報101に基づき、「セクショ ン3」の配置を行う。その後、配置手段304は、マッ ピング手段306を起動して、配置手段304が行った 「セクション3」の配置に基づいて、「セクション3」 のマッピングを行う。

【0119】トレース手段308は、「モジュール3」 のステップ実行を監視し、「モジュール3」のアクセス の履歴を所定の物理アドレスに書き込む。例えば図9の 物理アドレス空間PSの物理アドレス「0x90009 000」に書き込む。

【0120】トレース手段408は、アクセス例外に応 じてアクセスの履歴の書き込みを行ったことを履歴取得 手段410に通知する。履歴取得手段410は、トレー ス手段408がアクセスの履歴を書き込んだ物理アドレ 50 レース手段608、履歴取得手段410および時間管理

ス「0 x 9 0 0 0 9 0 0 0」からアクセスの履歴を取得 する。トレース手段408が書き込むアクセスの履歴と しては、例えば、アクセス例外が発生したか否かのフラ グやアクセス例外の回数を示すカウンタ値、アクセス例 外が発生したプログラム(命令)、アクセス例外が発生 した時刻、あるいはアクセス例外が発生した時点での何

らかの状態変数等がある。

【0121】その後、トレース手段408は、「セクシ ョン3」のマッピングの解除を配置手段304に指示す る。配置手段304は、マッピング手段306に「セク ション3」のマッピングを解除させる。それにより、新 たに「セクション3」の論理アドレスにアクセス要求が あった場合に、トレース手段408はアクセス例外を検 出することができる。

【0122】本実施の形態のメモリ管理装置400によ れば、「セクション3」の未対応の論理アドレスへのア クセス要求が契機となって、トレース手段408により 「セクション3」の論理アドレスへのアクセスの履歴が 物理アドレス「0 x 9 0 0 0 9 0 0 0」へ書き込まれた ときには、履歴取得手段410が「セクション3」の論 理アドレスへのアクセスの履歴を物理アドレス「0 x 9 0009000」から取得して、メモリへの特定アクセ スを監視することができる。それにより、メモリ管理装 置400の保守性を高めることができる。

【0 1 2 3】なお、配置手段 3 0 4 が、マッピング手段 306にマッピングを解除させる際に、マッピングを解 除する物理アドレスと論理アドレスとの対応関係を記憶 しておくことによって、再度マッピングする際に物理ア ドレスと論理アドレスとの対応関係が前回のマッピング と同じになるようにしてもよい。

【0124】なお、上記の実施の形態においては、ステ ップ実行完了後にアクセスの履歴の取得を行ったが、ス テップ実行のための命令発行前にアクセスの履歴の取得 を行ってもよい。

【0125】また、トレース定義309に定義されたセ クションへのアクセスは必ずトレースするように構成し ているが、トレースを選択的に行ってもよい。例えば、 トレース定義に条件を加え、トレース手段408がトレ ース定義の条件が真の場合のみトレース領域への書き込 みを行うようにしてもよい。例えば、未対応の論理アド レスにアクセスしてステップ実行を行う命令をランクづ けして、所定のランク以上の命令を実行する場合のみト レースするようにするという条件を加える。

【0126】(実施の形態4)図10は本発明の実施の 形態4におけるメモリ管理装置の構成を示すプロック図 である。

【0 1 2 7】図10に示すメモリ管理装置600は、配 置手段304、複数のアドレス変換表105、マッピン グ手段306、アドレス変換表切り換え手段107、ト

手段611を備える。

【0128】図10のメモリ管理装置600は、図8のメモリ管理装置400と同様に、複数のモジュール情報101、複数のセクション定義102、複数の空間定義103およびトレース定義309を保持している。

【0129】図10のメモリ管理装置600は、トレース手段608の機能がメモリ管理装置400のトレース手段408の機能と異なっている。また、メモリ管理装置600は、時間管理手段611を備えている点がメモリ管理装置400と異なっている。

【0130】時間管理手段611は、後述するトレース 手段608および履歴取得手段410を所定時間ごとに 繰り返し起動する。トレース手段608は、時間管理手 段611により起動されると、配置手段304に対して トレース定義309に定義されているセクションのマッ ピングの解除を指示する。そして、トレース手段608 は、プログラムの実行中に、物理アドレスに対応付けら れていない未対応の論理アドレスへのアクセス要求(ア クセス例外)を検出する。トレース手段608は、アク セス例外を検出すると、配置手段304にトレース定義 20 309を参照させ、セクション定義102とモジュール 情報101と空間定義103とに基づき、配置手段30 4に現在用いられているアドレス変換表105に対応す る論理空間にアクセス要求の出ているセクションのモジ ュールを配置させる。トレース手段608は、アクセス の履歴を所定の物理アドレスに書き込むとともに配置手 段304にマッピングの解除を指示する。

【0131】また、トレース手段608は、時間管理手段611がトレース手段608に対してアクセスの履歴の取得の中止を指示すると、配置手段304に対してトレース定義309に定義されているセクションのマッピングを指示する。

【0132】履歴取得手段410は、トレース手段608から与えられるアクセスの例外の発生の通知に応じて、トレース手段608がマッピングを解除する前に、トレース手段608がアクセスの履歴を書き込んだ物理アドレスからアクセスの履歴を取得する。

【0133】本実施の形態において、時間管理手段61 1が管理手段に相当する。なお、トレース手段608お よび時間管理手段611は、CPUがROM等の記憶装 40 置に記憶されたプログラムをRAM等のメモリ上で実行 することにより実施される。

【0134】次に、メモリ管理装置600の動作について説明する。メモリ管理装置600は、時間管理手段611がトレース手段608を起動してトレースの履歴を取得する状態になっている場合には、図8のメモリ管理装置400と同様の動作を行い、時間管理手段611によりトレース手段608が起動されていない場合には、図1のトレース手段108がアクセスの履歴の取得を行わない場合と同様の動作を行う。

【0135】本実施の形態のメモリ管理装置600においても、図1のメモリ管理装置100と同様に、タスク識別子241により示される「タスク1」およびタスク識別子242により示される「タスク2」のような互いに異なる2つのタスクが同一の「モジュール2」を共有することができる。また、マッピングの解除をアクセス要求があるごとに常に行うのではなく、時間管理手段611がトレース手段608を起動しているときだけ行い、メモリ管理装置600が効率よく動作する。なお、上記の実施の形態においては、所定の時間ごとにマッピングを解除するようにしたが、時間以外の別の要素をトリガとして利用して間欠的にトレース手段608および

【0136】なお、実施の形態1~4のメモリ管理装置100,300,400,600においては、配置手段104,304によって、共有するモジュールを異なる論理アドレス空間における同一論理アドレスに配置して同一のモジュールの論理アドレスを同一の物理アドレスに配置してに割り付けているが、共有するモジュールを異なる論理アドレス空間における異なる論理アドレスに配置して同一のモジュールの論理アドレスを同一の物理アドレスに割り付けるようにしてもよい。

履歴取得手段410を起動してもよい。

【0137】また、実施の形態1-4においては、モジュール情報101にプログラムのコードおよびデータのみに関する情報が記述されている場合について示したがスタックや初期値を有するデータ等の情報が記述されていてもよく、これらの情報をマッピングすることができる。

# [0138]

【発明の効果】本発明に係るメモリ管理装置によれば、必要なモジュール以外は異なるタスク間でメモリに直接アクセスすることを禁止し、必要なモジュールのみ異なるタスク間で共有させることができる。さらに、物理アドレスに対応付られていない未対応の論理アドレスへのアクセス要求を契機として、メモリへの特定アクセスを監視することができる。

# 【図面の簡単な説明】

【図1】本発明の実施の形態1によるメモリ管理装置の 構成を示すブロック図

【図2】図1のメモリ管理装置が保持するモジュール情報とセクション定義と空間定義の一例を示す概念図

【図3】図1のメモリ管理装置が行うマッピングの一例 を示す概念図

【図4】図1のメモリ管理装置が保持するモジュール情報とセクション定義と空間定義の他の例を示す概念図

【図5】本発明の実施の形態2によるメモリ管理装置の 構成を示すプロック図

【図6】図5のメモリ管理装置が保持するモジュール情報とセクション定義と空間定義とタスク定義の一例を示50 す概念図

【図7】図5のメモリ管理装置が行うマッピングの一例を示す概念図

【図8】本発明の実施の形態3によるメモリ管理装置の 構成を示すプロック図

【図9】図8のメモリ管理装置が行うマッピングの一例を示す概念図

【図10】本発明の実施の形態4によるメモリ管理装置の構成を示すブロック図

【図 1 1】従来のメモリ管理装置の構成を示すプロック 図

# 【符号の説明】

100.300.400.600 メモリ管理装置

101 モジュール情報

102 セクション定義

103 空間定義

104.304 配置手段

105 アドレス変換表

106.306 マッピング手段

107 アドレス変換表切り換え手段

108,308,408,608 トレース手段

110,310,410 履歴取得手段

10 309 トレース定義

611 時間管理手段

図1]



【図11】



【図3】



【図7】











【図10】.



# フロントページの続き

Fターム(参考) 5B005 LL04 MM32 SS14 VV12 VV24 5B017 BA06 BB08 CA01

SBUIT BAUG BBUG CAUI

5B042 GA23 GA33 GC08 HH30 JJ46

KK07 MA08 MC03 MC15

5B060 AB26 AC06 KA10

5B098 AA04 GA04 GD04 GD14 JJ07

JJ08